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Pronteir Description F5la Foinnniatt Generator 

BACKGROUND OF THE INVENTION 
TECHNICAL FIELD 

The invention relates to PostScript® Printer Description (PPD) files and more particularly 
to computer processes and systems for generating PPD files for printers. 

DESCRIPTION OF THE PRIOR ART 



A PostScript® Printer Description (PPD) file is a text file that describes the printer 
features unique to particular printers in particular environments to the PostScript® Printer 

15 Driver(s) available for that environment. Ubiquitous PostScript® printer driver 
executable program files are used to provide communications between an application 
program and PostScript®-enabled printers residing on the network. Each PPD file 
contains certain phrases that describe what a particular printer is capable of doing. PPD 
files are commonly created by manufacturers of PostScript® printers. The driver is 

20 created either by Adobe Systems, Inc., the creators of PostScript® language, or by 
provider of the particular operating system the user is using (whether it be Microsoft 
corporation in case of Windows or Apple Computers in case of Macintosh), or it is 
sometimes provided by manufacturers of different application programs that a user may 
be using. 

25 

A PPD file is not a printer driver. It is an information file, in ASCII format, that is used by 
a printer driver loaded by an operating system or application program. Because PPDs 
are all written in ASCI I -text format, they are not limited to a specific software 
environment or platform. An ASCII-text PPD file can therefore be used equally well in 
30 Windows, MAC-OS, and UNIX environments, and by a variety of software 
applications. Adobe Systems, Inc. (Sunnyvale, CA) has defined how PPD files must 
be constructed by printer and software vendors in the "PPD Specification," now at 
version 4.3. 



35 In general, a PPD file contains information that describe the capabilities of a particular 
printer to a printer driver. The driver then communicates some of this information to the 
end-user and allows him to choose certain features suited to the file being printed. For 
example, if the printer in question is color capable, has duplexing (ability to print to both 
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sides of the page) , and supports paper sizes Letter, Legal, and Tabloid, then printer 
drivers having access to this PPD are capable of providing this information to user using 
common user interface features such as popup menus and radio buttons. The user then 
selects a combination of the features available on that particular printer to be used when 
5 the data is at some point being printed. For example, a user may choose to print a 
certain word processing document to a letter-size page in black and white mode while 
the same or another user may decide to print another file containing graphics to a tabloid- 
size page in color. 

10 It is an unfortunate fact for the manufacturer of PPDs that all PostScript printer drivers that 
claim to conform to the Adobe PPD Specifications often do not behave in exact 
manners when using a PPD. There are several gray area situations in which a PPD file 
that works correctly for one printer driver, may fail in part when used by another driver. 
As a result, a manufacturer of PPDs has to provide several PPD files that are each suited 
n 15 for a particular environment so that a majority of potential users can take advantage of 
^ their benefits. One such situation arises with PPD files for languages other than English. 

ill 

j:j Since PPD files contain strings used in user-interface dialogs, these strings need to be 
CH translated for all supported languages. The way different drivers interpret non-English 
^ characters, such as "graves", "acutes" and "umlates", are different on different platforms. 
j;;20 So a French PPD for the Macintosh platform is different than a PPD for Windows 3.1 at 
* (% least when it comes to these strings. These PPDs may also be different due to technical 
Sj reasons determined by the printer/PPD manufacturer. For example, the manufacturer 
D may decide that a certain feature is to be supported only on Windows 95/98 platforms 
but not on Windows NT. 

%\j 25 

The conventional method of generating PPD files for different platforms and languages 
involves a significant amount of manual typing or "copy and paste" operations. This is an 
overwhelming task. Let us assume that at some point during the development of a 
printer, an engineer working for the printer manufacturing company is assigned the task of 

30 adding support for a new pagesize, A4, to all the PPDs pertaining to that product. The 
challenge is two-fold. First of all, he must come up with the ASCII text segments that 
must be added or changed in the existing PPD. Secondly, he must make these 
changes to every PPD the company is shipping for that printer. If the product line 
supports three languages and four platforms, he is faced with the daunting task of editing 

35 twelve (3 languages x 4 platforms) files. The conventional method, therefore, can be 
described as time-consuming and prone to human errors as each revision for a 
language-platform combination is constructed. 
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It would be advantageous to provide a system that generates all the necessary PPD 
files for all platforms and languages from a single source. 

SUMMARY OF THE INVENTION 

5 

The invention provides a PPD generator that generates all the necessary PPD files for 
all supported platforms and languages for the print engines in a particular manufacturer's 
product line from one or more base PPDs. TTie PPD generator uses an associated 
build file that contains information as to how the base PPDs are to be edited for all the 
10 supported languages, as well as exceptions to standard features attendant with a 
particular target platform/language. 

The PPD generator includes the following components: First, there is an initial setup 
section where several flags, or variables, are set to initial values that are used during the 
15 PPD generation process. Secondly, there is a routine set of procedures that are 
performed on almost all PPDs with small variations based on the initial flag values. 
Thirdly, there is a component that uses information contained in the build file to change 
further and shape some of the generated PPDs based on unique criteria that are specific 
to that particular product line's PPDs. 

20 

The invention enables maximum flexibility because an engineer can provide specific 
information regarding the needed changes for each platform, and it is only necessary, in 
most situations, to work on the single base PPD for each new revision after the build file 
is first created. Thus, the invention saves a significant amount of time that would 
25 otherwise be used to perform cut-and-paste operations, it minimizes the potential for 
human errors, it takes very little time to setup in most cases, and it provides an 
expansive method of customizing any number of PPDs based on the specific needs of 
a particular project. 

30 Table I illustrates how the number of PPD files that need to be supplied for each printer 
or application program can proliferate. A different PPD file is needed in each user 
application environment. 



3 



TABLE I. Typical PPD File Constellation 





Mac 


PC 


UNIX 


English 


English-Mac 


English-PC 


English-UNIX 


French 


French-Mac 


French-PC 


French-UNIX 


German 


German-Mac 


German-PC 


German-UNIX 


Japanese 


Japanese-Mac 


Japanese-PC 


Japanese-UNIX 



5 The reason that natural languages must be involved is that a printer driver must ask a 
user what printer features are to be selected. To do this, various spaces in conventional 
windows-type dialog boxes are presented on the computer screen. These spaces 
must be painted with an appropriate phrase scripted in the user's language. For 
example, it is very common for a printer driver literally to ask a user if letter, legal, A4, or 
C| 10 tabloid paper sizes are to be used in a print job. The user's selection is made by 
'£\ pressing a radio button in the dialog box, and this choice is used to setup the 

4* preferences for the printer. 

in 
w 

il l The words or phrases, letter, legal, A4, or tabloid are supplied by the base PPD 201 . 
B P 15 The fact that such paper sizes can each be selected at all is also supplied by the base 
p PPD. The computer platform for the operating system matters because some 
\l platforms cannot support particular features of the printer that other platforms can. 
p i Because the base PPD is a text file, and not executable code, the platform differences 
$ appear only as PostScript® and text string differences. 
\w 20 

Each base PPD comprises a text file of instructions and user strings that can be 
translated. One object of the invention is to provide a PPD generator to translate such 
portions. 

25 BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram that shows the interaction between the PPD, the PostScript 
printer driver, the printer, and the user; and 

30 Fig. 2 is a functional block diagram that shows how the base PPD and the build file 
interact with the PPD generator to create all the PPD files necessary to the project. 
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DETAILED DESCRIPTION OF THE INVENTION 

Fig, 1 is a block diagram that shows the interaction between a PPD, a PostScript printer 
5 driver, a printer, and an end user. In such system 100, the end user 20 operates a 
computer that is running a particular application program 18, such as Microsoft Word or 
Adobe PhotoShop. When the user wants to print from the program, a print file is sent 
to the PostScript printer driver 12. The PostScript printer driver accesses a PPD file 1 0 
which describes the capabilities of a particular printer 14 to the printer driver. The driver 
1 0 then communicates some of this information to the end-user and, as a result of a user 
dialog 14, allows him to choose certain features suited to the file being printed. The user 
then selects a combination of the features available on that particular printer to be used 
when the data are at some point being printed. 

1 5 Fig. 2 is a functional block diagram that shows how a base PPD and a build file interact 
with a PPD generator in the system 200 to create all the PPD files necessary for a 
project. For purposes of the discussion herein, a project is a PPD file for a specific 
language/platform combination, e.g. French and Unix. In the preferred embodiment of 
the invention, one or more base PPDs 201 are provided, where a base PPD is 

20 provided for each print engine in a particular manufacturer's product platform. For 
example, for the Xerox ZX Fiery product, a separate base PPD is provided for the 
5750 and 5760 copier models. For purposes of the discussion herein, a base PPD is 
best thought of as a quasi-PPD file that is used as a template during the PPD generation 
process. 

25 

The base PPD essentially mimics the PPD for one particular language and platform 
combination, for example, English-Macintosh. Thus, the original design is expressed 
only once in the base PPDs using the English-Macintosh version. This one parent or 
source is used by the PPD generator 202 in the automatic generation of all the other 
30 PPDs, e.g. for all other language/platform combinations 203-1 to 203-n and 207-1 to 
207-n, Thus, the conventional method of manually constructing each combinational PPD 
file is entirely avoided. 

In the preferred embodiment of the invention, each base PPD is a text file that includes 
35 PostScript® phrases and corresponding dialog window text strings that are related to 
particular features and user choices for a printer. The exact construction of a PPD file is 
described by Adobe Systems, Inc. (Sunnyvale, CA) in their widely circulated 
publication titled, PPD Specification, now at version 4.3. 
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The base PPD provides the generic framework needed to generate all PPD file 
varieties for a particular printer. Such PPD frameworks have components that must be 
tailored for the kind of platforms used and the natural language that users must see h 
5 page setup and printer setup dialog boxes. For example, the kinds of platforms can 
include WINDOWS, MacOS, UNIX, and OS/2. The kinds of languages can include, for 
example, English, French, German, and Japanese. Each such combination of platform 
and language is represented collectively by a project PPD file 203-1 to 203-n and 207- 
1 to 207-n. The PPD generator 202 is a generation engine that contains a routine set of 
1 0 operations that are found in all PPDs for all language and platform combinations. 

The invention also includes a build file 205 which (in the presently preferred 
embodiment of the invention) includes a single line for each base PPD that tells the PPD 
generator which languages must be created for converting that particular base PPD into 

1 5 all the varieties represented by the target PPD files 203-1 to 203-n and 207-1 to 207- 
n. The build file is used primarily to take care of platform specific issues. For example, if 
for some reason it is desired that the Windows 95 translation be different than all of the 
rest, a section is added to the build file that expresses that difference. The actual 
information that is necessary for a language translation, e.g. where an English word in a 

20 print dialog should be replaced by a French, is part of the PPD generator. For 
example, the build file may specify that the Xerox 5750 PPDs are to include French, 
while the Xerox 5760 PPDs are to include Italian. The actual translation files are not 
unique to a particular product line and are executed as part of the PPD generator. 

25 Furthermore, if two different printer manufacturers want different translation strings to be 
used for the same English word, for example, where the English string "Plain paper" is 
translated for one OEM as "Papier normal" and for another as "Papier ordinaire," one of 
the settings in the initial setup may be a variable named, e.g. OEMVersion. Based on 
that setting, a translation file in the PPD generator behaves differently for each printer 

30 manufacturer by using if statements. Thus, in this embodiment of the invention the initial 
settings are: 

Set OEMVersion "Xerox." 

35 When the actual translation scripts are running, and it is time for the English_to_French 
script, the translation scripts have a line, such as: 



(a 



# 
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if (OEMVersion) == "Xerox 



It 



translate "Plain paper 



" this way 



elseif {OEMVersion} 



== "Canon 



it 



5 



translate "Plain paper 



" this other way 



else 

translate "Plain paper" that way 

end 

1 0 Design changes and bug fixes are accommodated by changing the base PPD files and 
then running the PPD generator so that It generates a new group of PPD files for afl 
platform/language combinations. The build file is used to identify a particular product's 
peculiarities to the PPD generator and to instruct the PPD generator with regard to these 
□ peculiarities. Thus, the PPD generator applies a default set of translations to the base 
y'Hs PPDs, while the build file identifies both normal operations, such as language 
jj translations, and specific exceptions to the default that must be taken into account for the 
Cn project PPD. The PPD generator produces the project PPD as a result of its interaction 
with both the base PPDs and the build file. 

i r 20 Note: In the preferred embodiment of the invention, there is only one build file for each 
\l project (i.e. Xerox ZX). Each base PPD has its own section in that project's build file. 
P However, each PPD may alternatively have an associated build file in other 
embodiments of the invention. 

25 A base PPD file may be used for a virtually unlimited number of projects, where such 
projects can exist simultaneously for mass-marketed products, such as printers. 
Typically, only one set of base PPDs exists at the original equipment manufacturer's 
location. Key to the invention is the fad that a base PPD may be specified for any 
number of target projects and that a build file may be provided for project specific 

30 exceptions to a default conversion. Thus, the system assumes certain generic functions 
are to be provided for all PPDs that are generated, but these functions are easily 
reverted or changed, based upon specific project requirements. Further, system 
revisions are readily propagated throughout a product line to each language/platform 
combination by the simple expedient of changing the base PPDs and build file as 

35 appropriate. This avoids the need to rebuild each PPD manually for each project and 
language/platform combination. 
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Table II represents an English-language type PPD file. Table III represents a 
corresponding French-language type PPD file for the same printer. 

TABLE II. English-Language PPD 



*OpenUI *Ercompress ion/Compress ion :Pic)cOne 
*OrderDependency: 05.0 AnySetup *EFCoinpression 
*DefaultEFCompression: SCDe fault 
♦EPCompression SCDefault/Printer's Default: " n 
*EPCompression False/Off: " userdict /XJXsetRenderType known 

{ (ADOBE) XJXsetRenderType ) 

if 

*End 

♦EPConqpression True/On: " userdict /XJXsetRenderType known 
{ (AREND) XJXsetRenderType } 
if " 

*End 

♦CloseUI : *EFConpression 



TABLE III. French-Language PPD 



*OpenUI *EFCompression/Compression :PickOne 
*OrderDependency: 05.0 AnySetup *EFCompress ion 
*DefaultEPCompression: SCDefault 
*EFCompression SCDe fault /Urprimante par defaut: "" 
*EFCompression False/Non: " userdict /XJXsetRenderType known 

{ (ADOBE) XJXsetRenderType ) 

if M * 

End 

*EFCompression True/Oui: " userdict /XJXsetRenderType known 
{ (AREND) XJXsetRenderType } 
if M 

*End 

*CloseUI : *EPCorapression 



All the text strings in between a slash and colon pair are translated using automated 
scripts in the PPD generator. For example, in Table II, line 3, "Printer's Default 9 h 
40 English is replaced in Table III, line 3, by the French "Imprimante par defaut". Also, h 
Table II, line 7, "On" in English is replaced in Table III, line 7, by the French w Oui n , These 
text strings are output to the user in a dialog by printer driver 12 (Fig. 1). The base PPD 
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has only one of the necessary strings, all the others are translated by lookup files in the 
build file 205. Each time there is to be a design change, e.g. to add a new printer 
feature or modify an existing one, all the PPD files 203-1 to 203-n and 207-1 to 207-n 
for all the different languages and platforms are automatically generated by the PPD 
5 generator using the base PPDs and the build file. This is much faster in the manufacturing 
environment than trying to do a manual copy-and-paste operation one-at-a-time on each 
of PPD files. 



The build file for each project describes the build required for a particular printer to a main 
10 script in the PPD generator, e.g. a Canon versus a Xerox. The PPD generator opens 
the build file and searches for particular strings in the build file. If it finds them, then it 
knows something has to be done. Otherwise, it assumes nothing special needs to take 
place for that particularproject. For example, Table IV is a portion of a build file. 



fi15 TABLE IV 



m 
w 
m 

4=20 

s 

G 

n 

ru 



= new Mac only modifications 
find 0 

replace /"*OpenUI *InputSlotRest , 7:/"*CloseUI: *InputSlotRest"/ 
find • 

replace /"*OpenUI *InputSlotFirst"/:/"*CloseUI: *InputSlotFirst'V 
= end modifications 



The PPD generator searches the build file for "= new Mac only modifications". If found, 



v;i25 it executes everything between that and "== end modifications" 



In the above example, there are two "find the top of file" commands and two replace 
commands. One command replaces everything between "*OpenUI *lnputSlotRest" 
and "*CloseUI: *lnputSlotRest" with a blank (deleting them), and the next replace 
30 command similarly provides a delete function. 



The input to the system is a base PPD file. This is usually the Macintosh-English PPD, 
or a file that closely resembles the Mac/English PPD. The purpose is to translate the 
base PPD to different languages and also different platforms as needed by the project. 
35 Along with the needed base PPD(s), there is also the build file that contains information, 
parsable by the PPD generator, as to how the required project PPD(s) is different from 
a standard PPD generated solely based on default methods built into the generator. For 
example, assume we have a Xerox and then a Canon PPD. The build file in each case 
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instructs the scripting system how to go about doing each particular product's PPDs. The 
Xerox PPD may ship only for English and French languages, but the Canon may include 
also Italian and Japanese, and may also have other differences. 

5 Pseudo-code is used in Table V to state the operation in a way that resembles high 
level programming language. 

TABLE V 

10 

for each PPD in the "original PPD's" folder 

find the section in the build file corresponding to this PPD 
for each language from the build file for this PPD 

# start with Mac PPD 
duplicate the PPD to "Macintosh: {language} : " folder 
perform the English->{ language} translations 

# time to do windows PPD's, starting with Win31 
duplicate the Mac PPD to "(Language) :Win31 : " folder 

perform Mac->win31 operations 

# now Windows 95/98 
Duplicate the Win31 PPD to win95 folder 
perform Win31->win95 operations 

# repeat with win_nt_4.0 and win_nt_3.5 and if 

# needed (from the build file), also the OS/2 PPD's 
# here we look perform platform specific changes 
for each platform 

search build file for platform specific changes 
if found, perform these operations on needed PPDs 
end for each platform 
end of for each language 
end of for each PPD 



Although the present invention is described herein with reference to the preferred 
35 embodiment, one skilled in the art will readily appreciate that other applications may be 
substituted for those set forth herein without departing from the spirit and scope of the 
present invention. Accordingly, the present invention should only be limited by the 
Claims included below. 
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CLAIMS 




v 1 . A development environment for producing a platform-language constellation 
printer description files, comprising: 
5 at least one base printer description (PPD) text file for a single langtr^ge and a 
single platform combination for a particular printer; and 

a PPD generator connected to import said at least on^base PPD and to 



^ generate therefrom a plurality of PPD files for a variety of languages and platforms. 



1 0 2. The development environment of Claim 1 , further comprising; 

at least one build file that describes a produ^r platform specific set of features 
of said base PPD. 



3. A method for generating an original §et of printer description (PPD) text files, the 
1 5 method comprising the steps of: 

providing at least one base PF>D text file for a single language and a single 
Jl platform combination for a particular printer; 

CH providing at least one build file tinat describes a product or platform specific set of 
p features of said base PPD; and, 

4*20 generating at least one/set of PPD files from said base PPD and said build file. 

\j v 4. A method for revising an original set of printer description (PPD) text files, the 
method comprising the sreps of: 

beginning with it least one base PPD and at least one build file that are 
M!i25 responsible for generating at least one PPD file for at least one specific target 
environment; 

modifying ssfid at least one base PPD and/or said at least one build file into 
corresponding revised PPD and/or build files; and 

generating a revised set of PPD files from said revised base PPD and/or build file. 

30 

^5. A method for manufacturing printer description (PPD) text files, the method 
comprising the steps of: 

providing at least one base PPD; 
providing at least one build file; 
35 generating at least one set of PPD files from said base PPD and said build file. 



The/method of claim 5, further comprising the steps of: 
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-ser 



beginning with a base PPD and a build file that is responsible forjjenj 
of printer description (PPD) text files; 

modifying said base PPD and/or said build filejpkTa revised base PPD and/or a 
revised build file; and 

5 generating a revised set of PPD from said base PPD and said build file. 



Y\\ y< A development environment for producing a platform-language constellation of 
^ ' printer description files, coprfpiising: 

at least one baefe printer description (PPD) text file for a single language and a 
1 0 single platform combination for a particular printer; and 

a PPD/generator connected to import said at least one base PPD file and to 
generate4herefrom a plurality of PPD files for a variety of languages and platforms. 




n15 



8. The development^viroi 
at least ooe-btjild file. 




nfpfClaim 7, further comprising: 




9. The development environment of Claim 8, wherein^ 

said PPD generator parses said at least onpJSase PPD and said at least one 
build file into text based instructions that ar^arsed and assembled by PostScript® 
J;: 20 printer drivers. 



i/IO. A method for generating arf original set of printer description (PPD) text files, the 
method comprising the step^of: 

providing at least one base PPD; 

providing at lea^t one build file of text that describes a set of special features 
associated with a parocular printer when used in one particular platform environment; 

generating^ least one PPD text file based upon information provided by said 
base PPD and4aid build file. 



fir. 
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